# +----------------------------------------------------------------------
# | DjangoAdmin敏捷开发框架 [ 赋能开发者，助力企业发展 ]
# +----------------------------------------------------------------------
# | 版权所有 2021~2024 北京DjangoAdmin研发中心
# +----------------------------------------------------------------------
# | Licensed Apache-2.0 DjangoAdmin并不是自由软件，未经许可禁止去掉相关版权
# +----------------------------------------------------------------------
# | 官方网站: https://www.djangoadmin.cn
# +----------------------------------------------------------------------
# | 作者: @一米阳光 团队荣誉出品
# +----------------------------------------------------------------------
# | 版权和免责声明:
# | 本团队对该软件框架产品拥有知识产权（包括但不限于商标权、专利权、著作权、商业秘密等）
# | 均受到相关法律法规的保护，任何个人、组织和单位不得在未经本团队书面授权的情况下对所授权
# | 软件框架产品本身申请相关的知识产权，禁止用于任何违法、侵害他人合法权益等恶意的行为，禁
# | 止用于任何违反我国法律法规的一切项目研发，任何个人、组织和单位用于项目研发而产生的任何
# | 意外、疏忽、合约毁坏、诽谤、版权或知识产权侵犯及其造成的损失 (包括但不限于直接、间接、
# | 附带或衍生的损失等)，本团队不承担任何法律责任，本软件框架禁止任何单位和个人、组织用于
# | 任何违法、侵害他人合法利益等恶意的行为，如有发现违规、违法的犯罪行为，本团队将无条件配
# | 合公安机关调查取证同时保留一切以法律手段起诉的权利，本软件框架只能用于公司和个人内部的
# | 法律所允许的合法合规的软件产品研发，详细声明内容请阅读《框架免责声明》附件；
# +----------------------------------------------------------------------

# -*- coding:utf-8 -*-
from flask import make_response


class Middleware:
    def init_app(self, app):
        @app.before_request
        def app_before_request():
            return

        @app.before_first_request
        def app_before_first_request():
            return

        # @app.after_request
        # def app_after_request(response):
        #     '''
        #     被after_request钩子函数装饰过的视图函数
        #     ，会在请求得到响应后返回给用户前调用，也就是说，这个时候，
        #     请求已经被app.route装饰的函数响应过了，已经形成了response，这个时
        #     候我们可以对response进行一些列操作，我们在这个钩子函数中添加headers，所有的url跨域请求都会允许！！！
        #     '''
        #     response = make_response(response)
        #     response.headers['Access-Control-Allow-Origin'] = '*'
        #     response.headers['Access-Control-Allow-Methods'] = 'OPTIONS,HEAD,GET,POST'
        #     response.headers['Access-Control-Allow-Headers'] = 'x-requested-with,content-type,Authorization'
        #     return response

        # @app.after_request
        # def add_headers(response):
        #     response.headers.add('Access-Control-Allow-Origin', '*')
        #     response.headers.add('Access-Control-Allow-Headers', 'Content-Type,Authorization')

        # @app.after_request
        # def after_request(response):
        #     header = response.headers
        #     header['Access-Control-Allow-Origin'] = '*'
        #     header['Access-Control-Allow-Headers'] = 'Content-Type, Authorization'
        #     header['Access-Control-Allow-Methods'] = 'OPTIONS, HEAD, GET, POST, DELETE, PUT'
        #     return response


middleware = Middleware()
